<template>
  <div>
    <input type="text" v-model="keyword">
    <h2>{{keyword}}</h2>
  </div>
</template>

<script>
import {ref, customRef} from 'vue'
export default {
  name: 'App',
  setup(){
    function myRef(value){
      let timer
      return customRef((track,trigger) => {
        return {
          get(){
            console.log(`有人从myRef这个容器中读取数据了，我把${value}给他了`)
            track() //通知Vue追踪value的变化（提前和get商量一下，让他认为这个value是有用的）
            return value
          },
          set(newValue){
            console.log(`有人把myRef这个容器中数据改为了：${newValue}`)
            clearTimeout(timer)
            timer = setTimeout(() => {
              value = newValue
						  trigger() //通知Vue去重新解析模板
            }, 1000)
          }
        }
      })
    }

    // let keyword = ref('hello') //vue提供的ref
    let keyword = myRef('hello')  //自定义ref

    return {keyword}
  }

}
</script>

<style>

</style>
